



## The Intel x86 ISA

- Further evolution...
  - i486 (1989): pipelined, on-chip caches and FPU
    - Compatible competitors: AMD, Cyrix, ...
  - Pentium (1993): superscalar, 64-bit datapath
    - Later versions added MMX (Multi-Media eXtension) instructions
    - The infamous FDIV bug (read text book)
  - Pentium Pro (1995), Pentium II (1997)
    - New microarchitecture (see Colwell The Pentium Chronicles)
    - 57 new instructions
    - Primarily for multimedia applications (SIMD)
  - Pentium III (1999)
    - Added SSE (Streaming SIMD Extensions) and associated registers
    - Four 32-bit floating point operations in parallel
    - Useful in speech recognition, video encoding/decoding







## **Implementing IA-32**

- Complex instruction set makes implementation difficult:
  - Hardware translates instructions to simpler micro-operations:
    - Simple instructions: 1 1.
    - Complex instructions: 1 many.
  - Microengine similar to RISC.
- Comparable performance to RISC:
  - Compilers avoid complex instructions.

## **ARM & MIPS Similarities**

- ARM: the most popular embedded core.
- Similar basic set of instructions to MIPS.

|                       | ARM              | MIPS             |  |
|-----------------------|------------------|------------------|--|
| Date announced        | 1985             | 1985             |  |
| Instruction size      | 32 bits          | 32 bits          |  |
| Address space         | 32-bit flat      | 32-bit flat      |  |
| Data alignment        | Aligned          | Aligned          |  |
| Data addressing modes | 9                | 3                |  |
| Registers             | 15 × 32-bit      | 31 × 32-bit      |  |
| Input/output          | Memory<br>mapped | Memory<br>mapped |  |





| Το | p 10 | 80x86 | Instructions |
|----|------|-------|--------------|
|    |      |       |              |

| Rank | instruction           | Integer Average |
|------|-----------------------|-----------------|
| 1    | load                  | 22%             |
| 2    | conditional branch    | 20%             |
| 3    | compare               | 16%             |
| 4    | store                 | 12%             |
| 5    | add                   | 8%              |
| 6    | and                   | 6%              |
| 7    | sub                   | 5%              |
| 8    | move register-registe | r 4%            |
| 9    | call                  | 1%              |
| 10   | return                | 1%              |
|      | Total                 | 96%             |





